<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="./libs/vue3.js"></script>
    <script src="./libs/axios.min.js"></script>
</head>

<body>
    <div id="app">

        <h1>vue3中开发注册插件</h1>
        <hr>
        <home />

    </div>
</body>
<script>
    // 定义插件对象
    const axiosPlugin = {
        // app: 系统自动注入的vue应用实例
        install(app,baseUrl) {
            // 全局配置数据接口基础域名
            axios.defaults.baseURL=baseUrl;
            // 将axiox注册为全局属性
            app.config.globalProperties.$axios= axios;
        }
    }

    // 创建vue实例
    const app=Vue.createApp({});

    // 注册插件
    app.use(axiosPlugin,'https://cnodejs.org/api/v1');

    // 注册全局组件
    app.component('home', {
        template: `
            <div class="home">
                <ul>
                    <li v-for="item in list" :key="item.id">{{item.title}}</li>
                </ul>
            </div>
        `,
        data(){
            return {
                // 文章列表
                list:[]
            }
        },
        created() {
            // console.log(this.$axios);
            // 请求文章列表
            this.getArticleList();
        },
        methods:{
            // 请求文章列表
            getArticleList(){
                this.$axios.get('/topics').then(({data})=>{
                    if(data.success){
                        // console.log(data.data);
                        this.list=data.data;
                    }
                });
            }
        }
    });


    // 挂载vue应用实例
    app.mount('#app');

</script>

</html>